package com.wanghua.mall.ware.dao;

import com.wanghua.mall.ware.entity.WareSkuEntity;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 *
 * @author wanghua
 * @email 2367279431@qq.com
 * @date 2021-08-25 21:29:07
 */
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    //查询sku的总库存
    Integer getAllStock(@Param("skuId") Long skuId);

    /**
     * 查询哪些仓库有这个商品的库存
     *
     * @param skuId skuId
     * @return wareIdList
     */
    List<Long> listWareIdHasStockBySkuId(@Param("skuId") Long skuId);

    /**
     * 数据库锁定库存操作
     *
     * @param skuId  skuId
     * @param wareId 仓库id
     * @param count  要锁定的数量
     * @return
     */
    Long lockSkuStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("count") Integer count);

    /**
     * 执行数据库解锁库存操作
     *
     * @param skuId  商品id
     * @param wareId 仓库id
     * @param skuNum 要解锁的数量
     */
    void releaseLockStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("skuNum") Integer skuNum);
}
